WIDGET SERVO FUNCTIONAL OBJECTIVE 



I. BASIC SERVO FUNCTIONS 

Widget servo control functions are handled by a Z8 microprocessor. The 
Z8 handles all I/O operations, timing operations and communication with a 
host controller. Control functions to the Z8 Servo Controller are made 
through the serial I/O. 

The following commands for the Widget servo are: 

A. HOME - not detent ed, heads off data zones located at the inner stop. 

B. RECAL - detented at one of two positions. 

1. FORMAT RECAL: 32, -0, +3 tracks from HOME use only during data 
formatting. 

2. RECAL: 72, -0, +3 tracks from HOME use to initialize home posi- 
tion after power on or following an access or any other error. 

C. SEEK - coarse track positioning of data head to any desired track 
location. 

D. TRACK FOLLOWING - heads are detented on a specific track location and 
the device is ready for another command. 

E. OFFSET - controlled micro stepping of fine position system during 
TRACK FOLLOWING (two modes). 

1. COMMAND OFFSET - direction and amount of offset is specified to 
the servo. 

2. AUTO OFFSET - command allows the servo to automatically move off 
track by the amount indicated by the embedded servo signal on the 
data surface (disk). 

F. STATUS - command can read servo status. 

G. DIAGNOSTIC - not implemented. 

See Table 1 for the actual command description. With the present com- 
mand structure a SEEK COMMAND can be augmented with an OFFSET COMMAND. 
Upon completion of a seek, the offset command bit is tested to determine 
if an offset will occur following a seek (either auto or command offset). 



When a SERVO ERROR occurs the Z8 SERVO will attempt to do a short RECAL 
(ERROR RECAL). Two attempts are made by the system to do the ERROR RECAL 
function. If either of the two RECAL operations .terminate successfully 
the protocol status will be SERVO READY, SIO READY and SERVO ERROR. 
Should the ERROR RECAL fail then the system will complete the error 
recovery by a HOME function. 

The two OFFSET commands will be described. First COMMAND OFFSET is a pre- 
determined amount of microstepping of the fine position servo. Included 
in the OFFSET BYTE (STATREG) bit B6=0 is a COMMAND OFFSET. Bit B7=l is a 
,£erw^rd offset step (toward the spindle); B7=0 is a reverse step. In the 
case Mt B6=l the OFFSET command is AUTO OFFSET. 



AUTO OFFSET command normally occurs during a write operation. When the 
HDA was initially formated at the factory special encoded servo data was 
written on each track "near" the index zone. The reason for this follows: 



Normal coarse and fine position information for the position servos is 
derived from an optical signal relative to the actual data head-track 
location. Over a period of time the relative position (optical signal) 
will not be aligned to the absolute head-track position by some unknown 
amount (less than 100 uln). This small change is important for reliabil- 
ity during the write operation. Write/Read reliability can be degraded 
due to this misalignment. The special disk encoded servo signal is avail- 
able to the fine position servo and will correct the difference between 
the relative position signal of the optics and the absolute head to track 
position under the data head only at index time. The correction signal 
can be held indefinitely or updated (if desired at each index time) or 
until a new OFFSET command or move command (SEEK or RECAL) occurs. 



II. COMMUNICATION FUNCTIONS 

The servo functions described in the previous section only occur when the 
servo Z8 microprocessor is in the communication state. Communication 
states occur immediately after a system reset, upon completing head set- 
ting after a recal, seek, offset, read servo status or set servo diag- 
nostic. A special communication state exists after a servo error has 
occurred. If + SIO READY is not active no communication can exist between 
the external controller and the servo Z8 processor. 

Servo commands are serial bits grouped as five separate bytes total. Re- 
fer to Table 1 parts I through V as the total communication string. First 
byte is the command byte (i.e. seek, read status, recal, etc.). Second 
byte is the low order difference for a seek (i.e. Byte 2 = $0A is a ten 
track seek). Third byte is the offset byte (AUTO or COMMAND OFFSET and 
the magnitude/direction for command offset). Fourth byte is the status 
and diagnostic byte (use for reading internal servo status or setting 
diagnostic commands). Byte five is the check sum byte used to check ver- 
ify that the first four bytes were correctly transmitted (communication 
error checking) • 




Part of the communication function requires a specific protocol between 
the servo Z8 processor and the external controller. 

Servo control and communication are described in CHART I. This chart 
illustrates the basic sequencing and control operations. Chart I does 
not illustrate the servo error handling or command /protocol handling 
functions. Error handling is described in Section IV and illustrated by 
CHART II. 



III. Z8 SERVO PROTOCOL . 

The protocol between the Z8 SERVO microcomputer and the CONTROLLER is 
based on five I/O lines . Two of the I/O lines are serial input (to Z8, 
servo from controller) serial output (from Z8 servo to controller). Data 
stream between the Z8 servo and controller is 8 bit ACSII with no parity 
bit (the fifth byte of the command string contains check sum byte use for 
error checking). There are three additional output lines between the Z8 
servo used as control lines to the controller. Combining the two serial 
I/O lines and the three unidirectional port lines generates the bases of 
the protocol between the Z8 servo and controller. The important opera- 
tions between the Z8 servo and controller are: 

1. Send commands to Z8 servo. 

2c Read Z8 servo status. 

3. Check validity of all four command bytes* 

4. I/O timing signals between the Z8 servo and controller. 

5. Z8 servo reset. 

Sequencing the Z8 servo controller is an important process following a 
Power Up (Power On Reset) or if the controller should issue a Z8 Servo 
Reset at any time. After a Z8 Servo Reset is inhibited the Z8 I/O ports 
and internal register are initialized. This takes approximately 75 msec 
after the Z8 Servo Reset is inhibited. The protocol baud rate is auto- 
matically set to 19.2KB and then the system is parked at HOME position 
and SIO READY is set active. *** IMPORTANT*** • If the desired baud rate 
needs to be increased to 57.6KB; **after a Z8 Servo Reset is the ONLY 
time this can be done***. Once set to 57.6KB the communication rate re- 
mains at 57.6KB until a Z8 Servo Reset occurs. Setting 57.6KB is achieved 
as follows: 

1. Z8 Servo "Power On or Controller" Reset 

2. Wait for SIO Ready 

3. Send a READ STATUS COMMAND as follows: 

BYTE 1 = $ 00 
BYTE 2 = $ 00 
BYTE 3 = $ 00 
BYTE 4 = $ 87 



Afzer the ^completion of transmitting the bytes, the Z8 Servo Controller 
chanzges to 57.6KB and will be waiting for the next transmitted command 
at 5.7^6KB. 

Before the controller transmits the command byte the controller must pole 
the SIO READY line from the Z8 servo to determine if it is active (+5 
volts). If the line is active then a command can be transmitted to the 
Z8 servo. The program in the Z8 servo will determine what to do with the 
command bytes (depending upon the current status of the Z8 servo). After 
the command (five bytes long) has been transmitted to the Z8 servo, the 
program in the Z8 servo will determine if the command bytes (first four 
bytes) are in error by evaluating the check sum byte (fifth byte trans- 
mitted). See table Chart III and IV for the error handling. After the 
controller has transmitted the last serial string it must wait 250 usee 
then test for SERVO ERROR active (+5 volts). If SERVO ERROR is active the 
command was rejected (check sum error or invalid command). If the SERVO 
ERROR is set active SOO^sec after the command is sent (and not 250 sec), 
this was a command reject. The SERVO ERROR must be cleared by READ 
STATUS COMMAND or RECAL COMMAND before transmitting another command. 
See CHART 1 for time diagram of the command sequence and I/O protocol. 

As long as SIO READY is active the controller can communicate with the Z8 
Servo Controller. If SERVO READY is not active the only command that will 
cause the Widget Servo to set SERVO READY active is a RECAL COMMAND (NOR- 
MAL or FORMAT). Read Status will only clear SERVO ERROR. And all other 
commands will be rejected. 

Next, if SERVO READY is active and SERVO ERROR is also active, SERVO 
ERROR can be cleared by: 

1. Any READ STATUS COMMAND. 

2. Any RECAL COMMAND. 

3. Any other commands will be rejected and maintain SERVO ERROR. 

If a SEEK COMMAND is transmitted with both SERVO READY and SERVO ERROR 
active the command will be rejected. 

It is important to check the status of all three status lines from the 
Z8 Servo. It is best to avoid sending a SEEK COMMAND with SERVO READY 
and SERVO ERROR active. 

Chart V parts A- 1 illustrate some of the serial communication commands 
and error conditions that can occur between the controller and Z8 SERVO. 



IV. ERROR HANDLING 

SERVO ERROR will be generated during the following conditions: 

1. During Recal mode (velocity control only) access time-out. If a Recal 
function exceeds 150 msec then an access timeout occurs. 



During Seek mode (velocity control only) access time-out. If a Seek 
function exceeds 150 msec then an access time-out occurs. 

During Settling mode (following a Recal, Seek, or Offset) if there is 
excessive On Track pulses (3 crossings) indicating excessive head 
motion a Settling error check will occur. 

During a command transmission if a communication error occurs (check 
sum error). 

During a command tansmiss ion if a invalid command is sent. 



APPENDIX A: 



I. The purpose of the FINE POSITION SERVO is to maintain detent or lock on 
a given data track. Any misregistrations of the head/arm due to windage, 
mechanical observed by the optics position signal are corrected by the 
close loop position servo. Misregistrations at the data head relative to 
the actual data track on the disk must be corrected by the AUTO OFFSET 
command. Figure I illustrates a block diagram of the Widget FINE POSI- 
TION SERVO. The amount of misregistration at the data track sensed after 
a AUTO OFFSET command are summed into the servo and the servo is automat- 
ically repositioned over the data track. 

II. The COARSE POSITION SERVO (SEEK) has the function of moving the data 
head arbitarily from a current track to any other arbitrary track loca- 
tion within the total number of track locations between the inner to 
outer crash stops. When a command is transmitted to the Z8 Servo con- 
troller, the ZS decodes and interprets the command into a servo function. 
If a SEEK command is sent to the Z8 Servo Controller a direction and 
number of tracks to move is also sent. The system starts its move to the 
new track location. When the arm has moved to its new location the Z8 
Servo Controller provides control and delay necessary to allow the data 
head and the FINE POSITION SERVO to come to rest immediately following a 
SEEK* This insures that motion in FINE POSITION SERVO and data head will 
be under control when the READ/WRITE channel begins operation. Reliabil- 
ity of the data channel is assured with high margins. Figure I illustrates 
a block diagram of the Widget COARSE POSITION SERVO. 

The differences between the FINE POSITION SERVO and the COARSE POSITION 
SERVO is handled by the Z8 Servo Controller. The two servos share for 
the most part the same set of electronics. The Z8 Servo Controller and 
analog multiplexers switch between the signal paths. In general there 
are some circuits that are not shared because of their uniqueness for a 
particular servo. 



APPENDIX B: 



An important part of the Widget Servo System is the optics signalV The optics 
signals provide^ the necessary signals for the f itoe position servos-position the 
data head accurately over the data track and to provide the system velocity 
s±gna±- during seek mode. The alignment of the optics signal is described in 
the following section on "WIDGET OPTICS ALIGNMENT PROCEDURE • " 



WIDGET SERVO 



VARIOUS KEY WAVEFORMS 



CONTENTS 



Page 1 Optics Adjustment 

Page 2 Current Sense and Position A 

Page 3 Current Sense and Position A (Forward and Rev Seeks) 

Page 4 Velocity and Position A 

Page 5 Velocity and Position A (Forward and Rev Seeks) 

Page 6 DAC Output and Position A 

Page 7 DAC Output and Position A (Forward and Rev Seeks) 

Page 8 Curve Shift Function and Position A ( 1 track seek) 

Page 9 Curve Shift Function and Position A (60 track seek) 



^WAVEFORM: Optics Adjustment 



Scope Adjustments: 

Channel Probe Tip Test Point Notes 

Chan 1 Position A TP 9 2V/div 

Chan 2 Position B TP 8 2V/div 

Trig In Not used 

Iloriz : X-Y Mode 



Servo: 

Alternate Seeks, 512 tracks 

Press Z; 82, 0, 0, 

86, 0, 0, 
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♦WAVE FORI! : Current Sense and Position A 



Scope Adjustments: 

Channel Probe Tip Test Point Notes 

Chan 1 Current Sense TP 19 5V/div 

Chan 2 Position A TP 9 5V/div 

Trig In Access Mode TP27 Positive trig, Ext/ 10 

Horiz: 5ms/Div Calibrated 



/ Servo: 

Alternate Seeks, 96 tracks (Hex $60) 

Press Z; 80, 60, 0, 

84, 60, 0, 




WAVEFORM: Current Sense and Position A 
(Forward and Reverse Seeks) 



Scope Adjustments: 

Channel Probe Tip 



Chan 1 
Chan 2 
Trig In 



Current Sense 
Position A 
Access Mode 



Test Point Notes 

TP19 5V/div 

TP 9 5V/div 

TP27 Positive trig, Ext/ 10 



Horiz: 2ms/Div Uncalibrated 



Servo : 



Alternate Seeks, 96 tracks (Hex $60) 



Press Z; 



80, 60, 0, 
84, 60, 0, 




WAVEFORM: Velocity and Position A 



Scope Adjustments: 



Channel Probe Tip Test Point Notes 

Chan 1 Velocity TP 7 2V/div 

Chan 2 Position A TP 9 5V/div 

Trig In Access Mode TP27 Positive trig, Ext/ 10 

Horiz: 5ms /Div Calibrated 



Servo: 

Alternate Seeks, 96 tracks (Hex $60) 

Press Z; 80, 60, 0, 

84, 60, 0, 




WAVEFORM: Velocity and Position A 
(Forward and Rev Seeks) 



Scope Adjustments: 
Channel 

Chan 1 
Chan 2 
Trig In 



Probe Tip 

Velocity 
Position A 
Access Mode 



Test Point Notes 



TP 7 
TP 9 
TP27 



Horiz: 2ms/Div Uncalibrated 



5V/div 
5V/div 

Positive trig, Ext/ 10 



Servo: 



Alternate Seeks, 96 tracks (Hex $60) 



Press Z; 



80, 60, 0, 
84, 60, 0, 



SiflBSflfllfl 



mmmmm 
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WAVEFORM: DAG Output and Position A 



Scope Adjustments: 

Channel Probe Tip Test Point Notes 

Chan 1 DAC Output TP 13 2V/div 

Chan 2 Position A TP 9 5V/div 

Trig In Access Mode TP27 Positive trig, Ext/ 10 

Horiz: 5ms/Div Calibrated 



Servo: 

Alternate Seeks, 96 tracks (Hex $60) 

Press Z; 80, 60, 0, 

84, 60, 0, 




.WAVEFORM: DAC Output and Position A 
(Forward and Rev Seeks) 



Scope Adjustments: 



Channel Probe Tip Test Point Notes 

Chan 1 DAC Output TP13 2V/div 

Chan 2 Position A TP 9 5V/div 

Trig In Access Mode TP 27 Positive trig, Ext/ 10 

Horiz: 2ms/Div Uncalibrated 



Servo: 

Alternate Seeks, 96 tracks (Hex $60) 

Press Z; 80, 60, 0, 

84, 60, 0, 




WAVEFORM: Curve Shift Function and Position A 
(Forward and Rev Seeks: 1 track) 



Scope Adjustments: 

Channel Probe Tip Test Point Notes 

Chan 1 Curve Shift Func. TP12 2V/div 
Chan 2 Position A TP 9 5V/div 

Trig In Access Mode TP27 Positive trig, Ext/ 10 

Horiz: 2ms/Div Uncalibrated 



Servo: 

Alternate Seeks, 1 track 

Press Z; 80, 01, 0, 

84, 01, 0, 
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WAVEFORM: Carve Shift Function and Position A 
(60 track seek.) 



Scope Adjustments: 
Channel 

Chan 1 
Chan 2 
Trig- In 



Probe Tip 



Test Point 



Curve Shift Func. TP 12 
Position A TP 9 

Access Mode TP27 



Notes 

2V/div 
5V/div 

Positive trig, Ext/ 10 



Horiz: 5ms /Div Calibrated 



Servo: 

Alternate Seeks, 96 tracks (Hex $60) 

Press Z; 80, 60, 0, 

84, 60, 0, 
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Z8 SERVO COMMAND BYTES 
TABLE 1 



page 1 



I. BYTE I: COMMAND BYTE ( DIFCNTH) 



command 
bi ts 



access 
b i ts 





i B7 


B6 


B5 


B4 i 


FUNCTIONS 






! 1 





8 





access only 




IB7 


! 1 





8 


1 


' access wi th offset 




\B6 


i 8 


1 


8 


8 


normal recal (to trk 


72) 


:b5 


i 8 


1 


1 


1 


1 format recal (to trk 


32) 


:b4 


! 8 


8 


8 


1 


offset-trk following 






! 1 


1 


8 


8 


home-send to ID stop 






! 8 


8 


1 


8 i 


diagnostic command 




IB3 -X- not used 


! 


8 


8 


8 


read status command 





B2 -ac c e ss d i r e c t i on 
Bi -hi diff2 <512) 
B8 -hi diffl C256) 



access direction 




I 


< FORWARD i toward the sp 


ndle) 




at 





(REVERSE: away from the 


sp i ndl e) 


hi diff2 <512) 


ar 


1 


(512 tracks to go) 






at 





(not set) 




hi diffl (256) 




1 


(25d tracks to go> 






a* 





(not set)' 





II. BYTE 2s DIFF BYTE (DIFCNTL) 

command BYTE 2 contains the LOW ORDER DIFFERENCE COUNT for a seek 



IB7 


-bi t7- 


128 


tracks 


\B6 


-bi 


t<S» 


64 


tracks 


IBS 


-bi 


t5« 


32 


tracks 


\ B4 


-bi 


t4» 


16 


tracks 


!B3 


-bi 


t3» 


8 


tracks 


!B2 


-bi 


1 2« 


4 


tracks 


1 BI 


-bi 


ti= 


2 


tracks 


!B8 


-bi 


t0» 


1 


track 



28 SERVO COMMAND BYTES 
TABLE 1 
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III. BYTE 3: OFFSET BYTE ( STATREG ) 

command BYTE 3 contains the INSTRUCTION for an OFFSET COMMAND (seeK 
or during track following) 



IB7 -offset direction 

IB6 -auto offset function 

IBS -read offset value <after auto or manual) 

!B4 -offset bi t4 =16 

1B3 -offset bi t3 =8 

!B2 -offset bi t2 =4 

iBl -offset bit! »2 

IBS -offset bi t0 »1 



1. if offset command from BYTE 1 is followed by bit6 set (auto of f set ) ; 
offset direction <bi t7) read offset (bitS) and bits 4-9 are ignored 
but should be set to if not used. 

2. OFFSET DIRECTION =1 (FORWARD OFFSET: toward the spindle) 

=0 < REVERSE OFFSETsaway from the spindle) 

3. AUTO OFFSET »1 (normally used preceeding a wr i t * operation) 

■8-: (manual offset :MUST send di rec t i on and magnitude 
of offset) 

4. READ OFFSET »1 (read offset value from DAC$ i.e. after auto 

offset) 
=0 (no action) 

* READ OFFSET COMMAND desired after AUTO OFFSET MUST be sent as two 
seperate commands 



IV. BYTE 4: STATUS BYTE (CNTREG) 



communication rate 
power on reset 
not used 
not used 

status or diagnostic bits 

i 
i 



B?»0; Communication Rate is 19.2 KBAUD 

=1; Communication Rate is 57. 6 KBAUD 

B6=Q ; Power On Reset bit is no active 

=1; Power On Reset bit is active 



J B7 - 
{ B<& — 
IBS - 
!B4 - 
IBS - 
IB2 - 
I BI - 
IB8 - 



28 SERVO COMMAND BYTES 
TABLE 1 
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V. BYTE 5: CHECKSUM BYTE <CKSUM> 
CB7 B6 B5 B4 B3 B2 Bl B9 3 

results of the transmi t ted CHECKSUM BYTE are derived as: 

7BYTE 1 + BYTE 2 + BYTE 3 + BYTE 4) - CHECKSUM BYTE 

< + ) is defined as the addition o-f each BYTE 

<BYTE) is defined as the compliment of the BYTE <l-4> 

MI. The SERVO STATUS lines <SIO RDY, SERVO RDY, SERVO ERROR) must have the 
following conditions in order to send the listed 28 COMMANDS? 



SERVO STATUS 



S 



S 
R 

V 



S 
R 
V 







R 
D 
Y 



R 
D 
Y 



E 
R 
R 



28 SERVO CMD 



HEX 



accessConl y) 
access < of f se t ) 
recal (data) 
recal < format) 
park 

of f set < detent) 

status 

d i agnos t i c 



8X 
?X 
40 
78 
C8 
19 
80 
20 



1 

X 
X 
X 



X 



— i not impl i men ted 



0i 
91 
Xi 
Xi 
XI 
0! 
Xi 



X= e i ther ,1 
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WIDGET SERVO FUNCTIONAL OBJECTIVE 



BASIC SERVO FUNCTIONS 

Widget servo control functions are handled by a Z8 microprocessor. The 
Z8 handles all I/O oprations, timing operations and communication with a 
host controller. Control functions to the Z8 Servo Controller are made 
through the serial I/O. 

The following commands for the widget servo are: 

A. HOME_ - not detented heads off data zones located at the inner stop. 

B. RECAL - detented at two home positions. 
32- 

1. format RF.flAL: 64, "0, +3 tracks from HOME use only during data 
formatting. 

2. RECAL: 72, -0, +3 tracks from HOME use to initialize home posi- 
tion after power on or following an access or any other error. 

C. SEEK - coarse track positioning of data head on any desired track 
location. 

D. TRACK FOLLOWING - heads are detented on a specific track location and 
the device is ready for another command. 

E. OFFSET - controlled microstepping of fine position system during 
TRACK FOLLOWING (two modes). 

1. COMMAND OFFSET - direction and amount of offset is specified to 
the servo. 

2. AUTO OFFSET - command allows the servo to automatically move off 
track by the amount indicated by the embedded servo signal on the 
disk* 

F. STATUS - command can read servo status. 

G. DIAGNOSTIC - not implemented. 



See Table 1A for the actual command description. With the present com- 
mand structure a seek command can be augmented with an offset command. 



Upon completion of a seek the offset command bit vri.ll be tested so that 
an offset will occur immediately after a seek (either auto or command 
offset). 

When a SERVO ERROR occurs the Z8 SERVO will attempt to do a short RECAL 
(ERROR RECAL). Two attempts are made by the system to the ERROR RECAL 
function. If either of the two RECAL operations terminate successfully 
the protocol status will be SERVO READY, SIO READY and SERVO ERROR. 
Should the ERROR RECAL fail then the system will complete the error 
recovery by a HOME function. 

The two OFFSET commands will be further described. First COMMAND OFFSET 
is a predetermined amount of microstepping of the fine position servo. 
Included in the OFFSET BYTE (STATREG) bit B6=0 is a COMMAND OFFSET. Bit 
B7=l is a forward offset step (toward the spindle); B7=0 is a reverse 
step. In the case bit B6=l the OFFSET command is AUTO OFFSET. 

AUTO OFFSET command normally occurs during a write operation. When the 
HDA was initially formated at the factory special encoded servo data was 
written on each track "near" the index zone. The reason for this follows: 



Normal course and fine position information for the position servos is 
derived from an optical signal relative to the actual data head-track 
location. Over a period of time the relative position (optical signal) 
will not be aligned to the absolute head-track position by some unknown 
amount (less than 100 uln). This small change is important for the relia- 
bility during the write operation. Write/Read reliability can be degraded 
due to this misalignment. The special disk encoded servo signal is avail- 
able to the fine position servo and will correct the difference between 
the relative position signal of the optics and the absolute head to 
track position under the data head only at index time. The correction 
signal can be held indefinately or updated (if desired at each index 
time) until a new OFFSET command or move command (SEEK or RECAL) occurs. 



II. COMMUNICATION FUNCTIONS 

The servo functions described in the previous section only occur when the 
servo Z8 microprocessor is in the communication state. Communication 
states occur immediately after a system reset, upon completing head set- 
ting after a recal, seek, offset, read servo status or set servo diag- 
nostic. A special communication state exists after a servo error has 
occurred. If + SIO READY is not active no communication can exist between 
the external controller and the servo Z8 processor. 

Servo commands are serial bits grouped as five separate bytes total. Re- 
fer to Table 1 parts A through E as the total communication string. First 
byte is the command byte (i.e. seek, read status, recal, etc.). Second 
byte is the low order difference for a seek (i.e. Byte 2 = $0A is a ten 
track seek). Third byte is the offset byte (auto or command offset and 
the magnitude/direction for command offset). Fourth byte is the status 
and diagnostic byte (use for reading internal servo status or setting 
diagnostic commands). Byte five is the check sum byte used to check ver- 



ify that the first four bytes were correctly transmitted (communication 
error checking) • 

Part of the communication function requires a specific protocol between 
the servo Z8 processor and the external controller. 

Servo control and communication are described in STATE CHART I. This 
chart illustrates the basic sequencing and control operations. Chart I 
does not illustrate the servo error handling or command /protocol handling 
functions. Error handling is described in Section IV and illustrated by 
CHART II. 



III. Z8 SERVO PROTOCOL 

The protocol between the Z8 SERVO microcomputer and the CONTROLLER is 
based on five I/O lines. Two of the I/O lines are serial input (to Z8 
servo from controller) serial output (from Z8 servo to controller). Data 
stream between the Z8 servo and controller is 8 bit ACSII with no parity 
bit (the fifth byte of the command string contains check sum byte use for 
error checking) . There are three additional output lines between the Z8 
servo used as control lines to the controller. Combining the two serial 
I/O lines and the four unidirectional port lines generates the bas$s of 
the protocol between the Z8 servo and controller. The important opera- 
tions between the Z8 servo and controller are: 



1. 


Send commands to Z8 servo. 




2. 


Read Z8 servo status. 




3. 


Check validity of all four 


command bytes. 


4. 


I/O timing signals between 


the Z8 servo and controller. 


5. 


Z8 servo reset. 





Following a "power-on" of Z8 servo a Z8 servo reset must be transmitted 
to the Z8 servo to insure its proper operation. Once the Z8 servo has 
been reset the program loops in STATE 1 waiting for a serial I/O command 
from the controller. The controller must transmit the serial command at 
a baud rate of 19.2 KBAUD/SEC or 57.6 KBAUD/SEC. 

Before the controller transmits the command byte the controller must pole 
the SIO ready lijde from the Z8 servo to determine if it is active (+5 
volts). If the line is active then a command can be transmitted to the" 
Z8 servo. The program in the Z8 servo will determine what to do with the 
command bytes (depending upon the current status of the Z8 servo). After 
the command (five bytes long) has been transmitted to the Z8 servo, the 
program in the Z8 servo will determine if the command bytes (first four 
bytes) are in error by evaluating the check sum byte (fifth byte trans- 
mitted). See table ( ) page 3 for the error handling. After the con- 
troller has transmitted the last serial string it must wait 250 usee then 
test for SERVO ERROR active (+5 volts). If SERVO ERROR is active the 
command was rejected (check sum error). The SERVO ERROR must be cleared 
by READ STATUS COMMAND or RECAL COMMAND before transmitting another com- 



and. See CHART 1 for time diagram of the command sequence and I/O proto- 
col. 



APPENDIX A 

I. The purpose of the FINE POSITION SERVO is to maintain detent or lock on 
a given data track. Any misregistrations of the head/arm due to windage, 
mechanical observed by the optics position signal are corrected by the 
close loop position servo. Misregistrations at the data head relative to 
the actual data track on the disk must be corrected by the AUTO OFFSET 
command. Figure*** illustrates a block digram of the Widget FINE POSITION 
SERVO. The amount of misregistration at the data track sensed after a 
AUTO OFFSET command are summed into the servo and the servo is automat- 
ically repositioned over the data track. 

II. The COARSE POSITION SERVO (SEEK) has the function of moving the data 
head arbitarily from a current track to any other arbitary track location 
within the total number of track locations between the inner to outter 
crash stops. When a conm\and,,is transmitted to the Z8 Servo controller, 
the Z8 decodes and iv^^Tivfis the command into a servo function. If a 
SEEK command is sent to the Z8 Servo Controller a direction and number 

of tracks to move is also sent. The system starts its move to the new 
track location. When the arm has moved to its new location the Z8 Servo 
Controller provides control and delay necessary to allow the data head 
and the FINE POSITION SERVO to come to rest immediately following a SEEK. 
This insures that motion in FINE POSITION SERVO and data head will be 
under control when the READ/WRITE channel begins operation. Reliability 
of the data channel is assured with high margins. Figure *** illustrates 
a block diagram of the Widget COARSE POSITION SERVO. 

The differences between the FINE POSITION SERVO and the COARSE POSITION 
SERVO is handled by the Z8 Servo Controller. The two servos share for 
the most part the same set of electronics. The Z8 Servo Controller and 
analog multiplexers switch between the signal paths. In general there 
are some circuits that are not shared because of theiC uniqueness for a 
particular servo. 



Z8 SERVO COMMAND BYTES 
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I. BYTE 1: COMMAND BYTE < DI FCNTH) 



B7 B6 B5 B4 I FUNCTIONS 



! B7 

command ! B6 
bits IBS 
I B4 



I B3 -X- not used 
access I B2 -access direction 
bits IBi -hi di+"*2 (512) 

IB8 -hi diffl (256) 



1 











access only. 




1 








1 


access with o-F+'set 




9 


1 








normal recal < to trk 


72) 





1 


1 


1 


■format recal <to trk 


64) 











1 


o-f-f se t-trk -following 




1 


1 








park-send to ID stop 










1 





diagnostic command 
















read status command 





access direction = 1 <FORWARD: toward the spindle) 

= < REVERSE : away -from the spindle) 

hi diff2 (512) =1 <512 tracks to go) 

= (not set) 

hi dif-fl (256) = i (256 tracks to go) 

= (not set) 



II. BYTE 2: DIFF BYTE (DIFCNTL) 

command BYTE 2 contains the LOW ORDER DIFFERENCE COUNT -for a seek 



1 B7 


-bi 


t7= 


128 


tracks 


IB6 


-bi 


t6= 


64 


tracks 


IBS 


-bi 


ts= 


32 


tracks 


IB4 


-bi 


t4= 


16 


tracks 


IBS 


-bi 


t3= 


8 


tracks 


IB2 


-bi 


t2= 


4 


tracks 


IBI 


-bi 


ti = 


±. 


tracks 


1 B0 


-bi 


t0= 


1 


track 
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I'll. BYTE 3: OFFSET BYTE ( STATREG) 

command BYTE 3 contains the 
or during track following) 



INSTRUCTION for an OFFSET COMMAND (seek 



! B7 -offset direction 

! B6 -auto offset function 

! B5 -read offset value 

!B4 -offset bi t4 =16 

i B3 -offset bi t3 =8 

! B2 -offset bi t2 =4 

! BI -offset bi tl =2 

! B8 -offset bi t8 =1 



(after auto or manual) 



if offset command from BYTE 1 is followed by bi t6 set (auto offset); 
offset direction (bi t7) read offset (bi t5) and bits 4-8 are ignored 
but should be set to 8 if not used. 

OFFSET DIRECTION =1 < FORWARD OFFSET : toward the spindle) 

=8 < REVERSE OFFSET; away from the spindle) 



3. AUTO OFFSET 



=i (normally used preceeding a write operation) 
=8 (manual offset :MUST send direction and magnitude 
of offset) 



READ OFFSET 



=1 (read offset value from DACji.e. after auto 

offset) 
=8 (no action) 



* READ OFFSET COMMAND desired after AUTO OFFSET MUST be sent as two 
seperate commands 



IV. BYTE 4: STATUS BYTE (CNTREG) 



! B7 -not used . - v ; 

! B6 -not used 
! B5 -not used 
! B4 -not used 

! B3 -status or diagnostic bits 
! B2 - ! 
i BI - ! 
!B8 - V 



ZS SERVO COMMAND BYTES 
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V. BYTE 5s CHECKSUM BYTE (CKSUM) 
CB7 B6 B5 B4 B3 B2 Bl B8 3 

results of the transmitted CHECKSUM BYTE are derived as: 

BYTE 1 + BYTE 2 + BYTE 3 + BYTE 4 = CHECKSUM BYTE 
< + ) is defined as the addition of each BYTE 
<BYTE) is defined as the compliment of each BYTE 
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WIDGET OPTICS ALIGNMENT PROCEEDURE 



INTRODUCTION 

The purpose of this note is to describe the procedure for properly adjusting 
five pots on the widget mother board used to control the amplitude of the optics 
signal. The five pots are R7 , R8, R17, R19 and R35. The optics signal 
originates at the end of the servo arm and is used in positioning the arm. 



EQUIPMENT REQUIRED 

An oscilloscope capable of operating in the X-Y mode of operation. A Tektronix 
model 465 works fine. 



PROCEEDURE 

Optics LED Drive Adjustment 

1. Connect channel 1 of the oscilloscope to TP 5 on the Widget Mother Board. 

2. Scope Vert, setting: 1 Volt/Div. Horizontal: Any sweep rate. 

3. Adjust R35 so the voltage at TP5 is 3.6 volts +/- .2 volts. 

(clockwise, or more resistances ower voltage) 



Figure 1: TP5 Amplitude 



Position A and Position B Adjustment 



4. 



5. 



7. 
8. 



9. 



Put scope in X-Y mode, ground channels X and Y, move dot to 
center of screen. z»* -^s&uo ^££>- 

Connect chan X to TP9, chan Y to TP8 V (Both TP's are located 
near pin 1 of the Z8 microprocessor) 

Scope vertical: Chan X and Y, 2 volts/Div. 

At this point arm is to be moved. ** to be determined how ** 

With arm in movement, a circular pattern should appear on the 
scope. Adjust R7, R8, R17, R19 so the top, bottom, right 
and left sides of the circle come at but no closer than a 
minimum of 2.5 scope divisions from the center of the screen. 

Each pot adjusts the circle as foil ows : 



R7 
R8 
R17 
R19 



Left side 
Right side 
Bottom 
Top 



clockwise or lower res=smaller circle 



10. Figure 2 shows a properly adjusted optics signal. 



Figure 2: Position A and B 




PROCEEDURE SUMMARY 



ZS jMV. 
\/ 



1. Adjust R35 so the voltage at TP5 (R37) is 3.6 Volts +/- .2 volts. 

2. Put scope in X-Y mode, chan 1 & 2 set to 2 volts/div. Adjust R7, 

R8, R17, R19, so that the sides of the circle (during minimum 
fluctuation) are each within 2.5 Divisions (+/- .1 div) of the 
center. This corresponds to 5 Volts from the center to the 
top, bottom, or either side. 



ADDITIONAL INFORMATION NEEDED FOR WALT WEBBER 



To provide information to convert the resistor trimming process into a laser- 
trimming process, Walt Webber needs the following information: 

1. The actual final resistor value of R34 and R35 on a properly adjusted mother- 
board. (LED current drive adj.) 

2. The final resistor value of the resistor pairs for adjusting the sides of 
the circle: pairs RP1 and R7, RP1 and R8, RP1 and R17, RP1 and R19. 

3. Data from 20 to 50 boards is necessary for a good cross section. 



Dan Retzinger 
Dec. 8, 1982 



WIDGET OPTICS AND TACH ADJUSTMENT PROCEEDURE 



INTRODUCTION 



The purpose of this note is to describe the procedure for adjusting five pots on 

the widget mother board used to control the amplitude of the optics signal (R7, 

R8, R17, R19 and R35). Also, the Tach adjustment pot (R25) and the Tach zero 
offset (R32) adjustments are described. 



EQUIPMENT REQUIRED 

An oscilloscope capable of operating in the X-Y mode of operation. A Tektronix 
model 465 works fine. 



PROCEEDURE 

Optics LED Drive Adjustment 

1. Connect channel 1 of the oscilloscope to TP 5 on the Widget Mother Board. 

2. Scope Vert, setting: 1 Volt/Div. Horizontal: Any sweep rate. 

3. Adjust R35 so the voltage at TP 5 is 3.6 volts +/- .2 volts. 

(clockwise, or more resistance^ ower voltage) 
NOTE: It may be necessary to change R34 in the mother bd. if the 
pot (R35) does not allow 3.6 volts to be reached. 
R34 smaller- higher voltage. 



Fi gure 1 : TP5 Amp! i tude 




4. Put scope in X-Y mode, ground channels X and Y, move dot to 

center of screen. 

5. Connect chan X to TP9, chan Y to TP8. (Both TP's are located 

near pin 1 of the Z8 microprocessor) 

6. Scope vertical: Chan X and Y, 2 volts/Div. 

7. At this point arm is to be moved. ** to be determined how ** 

8. With arm in movement, a circular pattern should appear on the 

scope. Adjust R7, R8, R17, R19 so the top, bottom, right 
and left sides of the circle come at but no closer than a 
minimum of 2.5 scope divisions from tne center of the screen. 

9. Each pot adjusts the circle as follows: 

R7 Left side clockwise or lower res=smaller circle 
R8 Right side 

R17 Bottom " 
R19 Top 

10. Figure 2 shows a properly adjusted optics signal. 



Figure 2: Position A and B 




,Vi|/J. 



Tach Adjustment 



11. The tach pot (R25) is adjusted while seeking alternate 60 (hex) track 

seeks. 

12. With Dan Retzinger's Servo software, enter "Z" for alternate, then 

80 <Ret>, 60 <Ret>, 00 <Ret>, 00 <Ret> 
84 <Ret>, 60 <Ret>, 00 <Ret>, 00 <Ret> 

13. Connect scope Chan 1 to TP9 

Scope Vert. 5 Volts/Div. 
Scope Horizontal 5ms. /Div 
Ext. trig TP 27 

14. Adj. Tach pot R25 for 35ms total seek time. 



Figure 3: Tach Adj . 




< 35 ms ic,t\. 



Tach Zero Offset Adjustment 

15. Move scope daan. 1 probe to TP7. (near pin 1 of Z8) 

16. With drive in Recal mode, adj. R32 to zero volts, +/- .05 Volts 



PROCEEDURE SUMMARY 



1. Adjust R35 so the voltage at TP 5 (R37) is 3.6 Volts +/- .2 volts. 

2. Put scope in X-Y mode, chan 1 & 2 set to 2 volts/div. Adjust R7, 

R8, R17, R19, so that the sides of the circle (during minimum 
fluctuation) are each within 2.5 Divisions (+/- -1 d1v) of the 
center. This corresponds to 5 Volts from the center to the 
top, bottom, or either side. 

3. Adjust R25 for 35ms 60 track seek time. 

4. Adjust R32 for zero voltage tack offset after Recal . 



ADDITIONAL INFORMATION NEEDED FOR WALT WEBBER 

To provide information to convert the resistor trimming process into a laser 
trimming process, Walt Webber needs the following information: 

1. The actual final resistor value of R34 and R35 on a properly 

adjusted mother board. (LED current drive adj.) 

2. The final resistor value of the resistor pairs for adjusting the 

sides of the circle: pairs RP1 and R7, RP1 and R8, RP1 and R17, 
RP1 and R19. 



